@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg:#f8f9fa;--surface:#fff;--surface-2:#f1f3f5;--surface-3:#e9ecef;--border:#dee2e6;--accent:#3f4ea7;--accent-dim:#2c3675;--accent-blue:#17b2ac;--accent-blue-2:#8de4e0;--text:#212529;--text-muted:#495057;--text-dim:#6c757d;--success:#10b981;--warning:#f59e0b;--danger:#ef4444;--radius-sm:8px;--radius:12px;--radius-lg:20px;--shadow:0 4px 24px #0000000f;--shadow-lg:0 8px 48px #0000001f;--transition:all .2s cubic-bezier(.4,0,.2,1)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.6}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--surface)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-dim)}.app-shell{height:100vh;display:flex;overflow:hidden}.main-content{background:var(--bg);flex:1;padding:32px 36px;overflow-y:auto}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.card-sm{padding:16px}.card-lg{padding:32px}.btn{border-radius:var(--radius-sm);transition:var(--transition);white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-size:14px;font-weight:600;display:inline-flex}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-dim);transform:translateY(-1px);box-shadow:0 4px 16px #3b82f64d}.btn-secondary{background:var(--surface-2);color:var(--text);border:1px solid var(--border)}.btn-secondary:hover{background:var(--surface-3);border-color:var(--accent)}.btn-ghost{color:var(--text-muted);background:0 0;border:1px solid #0000}.btn-ghost:hover{color:var(--text);border-color:var(--border)}.btn-danger{color:var(--danger);background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover{background:#ef444440}.btn:disabled{opacity:.45;cursor:not-allowed;transform:none!important}.btn-lg{padding:14px 28px;font-size:15px}.btn-sm{padding:6px 14px;font-size:12px}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:500}.form-input{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);transition:var(--transition);outline:none;width:100%;padding:11px 14px;font-size:14px}.form-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #3b82f626}.form-input::placeholder{color:var(--text-dim)}select.form-input{appearance:none;cursor:pointer}.choice-grid{gap:10px;display:grid}.choice-grid-2{grid-template-columns:1fr 1fr}.choice-grid-3{grid-template-columns:1fr 1fr 1fr}.choice-btn{background:var(--surface-2);border:1.5px solid var(--border);border-radius:var(--radius-sm);color:var(--text);transition:var(--transition);text-align:left;cursor:pointer;align-items:center;gap:12px;padding:14px 16px;font-size:14px;font-weight:500;display:flex}.choice-btn:hover{border-color:var(--accent);background:var(--surface-3)}.choice-btn.selected{border-color:var(--accent);color:var(--accent);background:#3b82f61a}.choice-badge{background:var(--surface-3);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;min-width:28px;height:28px;font-size:12px;font-weight:700;display:flex}.choice-btn.selected .choice-badge{background:var(--accent);color:#fff}.badge{letter-spacing:.03em;border-radius:99px;align-items:center;padding:3px 10px;font-size:11px;font-weight:600;display:inline-flex}.badge-yellow{color:var(--warning);background:#f59e0b2e}.badge-blue{color:var(--accent-blue-2);background:#5b8db833}.badge-green{color:var(--success);background:#22c55e26}.badge-red{color:var(--danger);background:#ef444426}.badge-gray{background:var(--surface-3);color:var(--text-muted)}.data-table{border-collapse:collapse;width:100%}.data-table th{background:var(--surface-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;text-align:left;border-bottom:1px solid var(--border);padding:12px 16px;font-size:11px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text);padding:14px 16px;font-size:13px}.data-table tbody tr{transition:var(--transition)}.data-table tbody tr:hover{background:var(--surface-2)}.data-table tbody tr:last-child td{border-bottom:none}.page-header{margin-bottom:28px}.page-title{color:var(--text);font-size:24px;font-weight:700}.page-subtitle{color:var(--text-muted);margin-top:4px;font-size:14px}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:28px;display:grid}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px 24px;position:relative;overflow:hidden}.kpi-card:before{content:"";background:var(--accent);border-radius:var(--radius) var(--radius) 0 0;height:3px;position:absolute;top:0;left:0;right:0}.kpi-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:11px;font-weight:600}.kpi-value{color:var(--text);margin-top:8px;font-size:32px;font-weight:800;line-height:1}.kpi-sub{color:var(--text-muted);margin-top:6px;font-size:12px}.wizard-progress{margin-bottom:32px}.wizard-progress-bar-track{background:var(--surface-3);border-radius:2px;height:4px;overflow:hidden}.wizard-progress-bar-fill{background:linear-gradient(90deg, var(--accent-blue), var(--accent));border-radius:2px;height:100%;transition:width .4s}.wizard-steps{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.wizard-step-dot{border:1px solid var(--border);color:var(--text-muted);background:var(--surface-2);transition:var(--transition);border-radius:99px;padding:3px 10px;font-size:11px;font-weight:600}.wizard-step-dot.active{background:var(--accent);color:#fff;border-color:var(--accent)}.wizard-step-dot.done{color:var(--accent);border-color:var(--accent);background:#3b82f626}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:var(--transition);background:var(--surface);padding:56px 40px}.dropzone:hover,.dropzone.active{border-color:var(--accent);background:#3b82f60f}.dropzone-icon{margin-bottom:16px;font-size:48px}.dropzone-title{color:var(--text);font-size:18px;font-weight:700}.dropzone-sub{color:var(--text-muted);margin-top:6px;font-size:13px}.result-card{background:linear-gradient(135deg, var(--surface) 0%, var(--surface-2) 100%);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:center;padding:36px;position:relative;overflow:hidden}.result-card:before{content:"";pointer-events:none;background:radial-gradient(circle,#3b82f624 0%,#0000 70%);width:200px;height:200px;position:absolute;top:-60px;left:-60px}.result-segment{color:var(--accent);margin:12px 0;font-size:28px;font-weight:800}.result-confidence{color:var(--text-muted);font-size:14px}.confidence-ring{background:conic-gradient(var(--accent) calc(var(--pct) * 1%), var(--surface-3) 0);border-radius:50%;justify-content:center;align-items:center;width:100px;height:100px;margin:0 auto 16px;display:flex;position:relative}.confidence-ring:after{content:"";background:var(--surface);border-radius:50%;position:absolute;inset:12px}.confidence-ring-label{z-index:1;color:var(--text);font-size:18px;font-weight:800;position:relative}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-4{gap:4px}.gap-8{gap:8px}.gap-16{gap:16px}.gap-24{gap:24px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}.w-full{width:100%}.text-center{text-align:center}.text-muted{color:var(--text-muted)}.text-accent{color:var(--accent)}.font-bold{font-weight:700}.divider{background:var(--border);height:1px;margin:20px 0}.spinner{border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;flex-shrink:0;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.warning-box{border-radius:var(--radius-sm);color:var(--warning);background:#f59e0b1a;border:1px solid #f59e0b4d;padding:12px 16px;font-size:13px}.login-page{justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg{filter:brightness(.9)saturate(1.1);background-position:50%;background-size:cover;position:absolute;inset:0}.login-overlay{background:linear-gradient(135deg,#ffffffb3 0%,#f1f3f5d9 60%);position:absolute;inset:0}.login-card{z-index:10;border-radius:var(--radius-lg);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);width:420px;box-shadow:var(--shadow-lg);background:#fffffff2;border:1px solid #00000014;padding:48px 40px;position:relative}.login-logo{align-items:center;gap:12px;margin-bottom:32px;display:flex}.login-logo-mark{background:var(--accent);color:#fff;border-radius:10px;justify-content:center;align-items:center;width:48px;height:48px;font-size:22px;font-weight:900;display:flex}.login-logo-text{color:var(--text);font-size:20px;font-weight:800}.login-logo-sub{color:var(--text-muted);font-size:12px}.login-title{margin-bottom:6px;font-size:26px;font-weight:800}.login-sub{color:var(--text-muted);margin-bottom:32px;font-size:14px}.login-error{border-radius:var(--radius-sm);color:var(--danger);background:#ef44441f;border:1px solid #ef44444d;margin-bottom:16px;padding:10px 14px;font-size:13px}.sidebar{background:var(--surface);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;height:100vh;display:flex;overflow-y:auto}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:12px;padding:24px 20px 20px;display:flex}.sidebar-logo-mark{background:var(--accent);color:#fff;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:38px;height:38px;font-size:16px;font-weight:900;display:flex}.sidebar-brand-name{color:var(--text);font-size:15px;font-weight:800;line-height:1.2}.sidebar-brand-sub{color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;font-size:10px}.sidebar-nav{flex:1;padding:16px 12px}.sidebar-section-label{color:var(--text-dim);text-transform:uppercase;letter-spacing:.1em;padding:8px 8px 6px;font-size:10px;font-weight:700}.sidebar-link{border-radius:var(--radius-sm);color:var(--text-muted);transition:var(--transition);align-items:center;gap:10px;margin-bottom:2px;padding:10px 12px;font-size:14px;font-weight:500;display:flex;position:relative}.sidebar-link:hover{background:var(--surface-2);color:var(--text)}.sidebar-link.active{color:var(--accent);background:#3b82f61f;font-weight:600}.sidebar-link.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:3px;position:absolute;top:6px;bottom:6px;left:0}.sidebar-link-icon{font-size:18px}.sidebar-footer{border-top:1px solid var(--border);padding:16px 20px}.sidebar-user{align-items:center;gap:10px;display:flex}.sidebar-avatar{background:linear-gradient(135deg, var(--accent-blue), var(--accent));color:#fff;border-radius:50%;justify-content:center;align-items:center;width:34px;height:34px;font-size:13px;font-weight:700;display:flex}.sidebar-user-name{color:var(--text);font-size:13px;font-weight:600}.sidebar-user-role{color:var(--text-muted);font-size:11px}.sidebar-logout{color:var(--text-muted);transition:var(--transition);background:0 0;border:none;border-radius:6px;margin-left:auto;padding:4px;font-size:18px}.sidebar-logout:hover{color:var(--danger);background:#ef44441a}.mapper-table{border-collapse:collapse;width:100%}.mapper-table th{background:var(--surface-2);color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;text-align:left;border-bottom:1px solid var(--border);padding:10px 14px;font-size:11px;font-weight:600}.mapper-table td{border-bottom:1px solid var(--border);padding:10px 14px;font-size:13px}.mapper-table tr:last-child td{border-bottom:none}.mapper-required{color:var(--danger);margin-left:4px;font-size:12px}.mapper-optional{color:var(--text-dim);margin-left:4px;font-size:12px}@media (width<=900px){.sidebar{width:64px}.sidebar-brand-name,.sidebar-brand-sub,.sidebar-link-label,.sidebar-section-label,.sidebar-user-name,.sidebar-user-role{display:none}.sidebar-brand{justify-content:center}.sidebar-link{justify-content:center;padding:12px}.sidebar-link:before{display:none}.main-content{padding:20px 16px}}
