.wrap{max-width:1060px;margin:0 auto;padding:1.5rem 1.25rem 4rem}.hero{text-align:center;padding:1rem 0 1.5rem}.hero h1{font-size:2rem;font-weight:800;letter-spacing:-.04em;margin-bottom:.25rem}.hero h1 span{color:var(--accent)}.hero p{color:var(--text-muted);font-size:.9rem;max-width:520px;margin:0 auto}.drop{border:2px dashed var(--border);border-radius:var(--radius);padding:2.5rem 2rem;text-align:center;cursor:pointer;transition:.2s;position:relative;margin-bottom:1rem}.drop:hover,.drop.drag{border-color:var(--accent);background:var(--accent-soft)}.drop input{position:absolute;inset:0;opacity:0;cursor:pointer}.drop-icon{margin:0 auto 10px;width:48px;height:48px;border-radius:12px;background:var(--card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text-dim)}.drop-t{font-weight:600;margin-bottom:3px}.drop-s{font-size:.82rem;color:var(--text-dim)}.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px 20px;margin-bottom:12px}.panel-t{font-size:.92rem;font-weight:700;margin-bottom:12px;display:flex;align-items:center;gap:8px}.panel-t svg{width:16px;height:16px;color:var(--accent)}select.inp{width:100%;padding:10px 34px 10px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.88rem;outline:0;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%234a5f7d' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;transition:.15s}select.inp:focus{border-color:var(--accent)}.inp{padding:9px 14px;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font);font-size:.86rem;outline:0;transition:.15s;width:100%}.inp:focus{border-color:var(--accent)}.inp::placeholder{color:var(--text-dim)}.btn{padding:12px 28px;border-radius:var(--radius-sm);border:0;background:var(--accent);color:var(--bg);font-size:.9rem;font-family:var(--font);font-weight:700;cursor:pointer;transition:.12s}.btn:hover{filter:brightness(1.1)}.btn:active{transform:scale(.97)}.btn:disabled{opacity:.3;cursor:not-allowed}.btn-o{padding:9px 18px;border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--card);color:var(--text-muted);font-size:.82rem;font-family:var(--font);font-weight:500;cursor:pointer;transition:.12s}.btn-o:hover{border-color:var(--border);color:var(--text)}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin-bottom:14px}@media (max-width:550px){.stats{grid-template-columns:1fr 1fr}}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;text-align:center}.stat-v{font-size:1.3rem;font-weight:800;font-family:var(--mono)}.stat-l{font-size:.66rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-top:2px}.map-table{width:100%;border-collapse:collapse}.map-table th{text-align:left;padding:10px 12px;background:var(--card);border:1px solid var(--border);font-size:.75rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.map-table td{padding:8px 12px;border:1px solid var(--border);font-size:.84rem;vertical-align:middle}.map-table tr:hover{background:var(--card)}.csv-col{font-family:var(--mono);font-weight:500;color:var(--accent);font-size:.82rem}.sf-field{font-family:var(--mono);font-size:.78rem;color:var(--accent)}.map-sel{width:100%;padding:7px 28px 7px 10px;background:var(--border);border:1px solid var(--border);border-radius:6px;color:var(--text);font-family:var(--mono);font-size:.78rem;outline:0;cursor:pointer;-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg width='8' height='5' viewBox='0 0 8 5' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1l3 3 3-3' stroke='%234a5f7d' stroke-width='1.2' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;transition:.15s}.map-sel:focus{border-color:var(--accent)}.map-sel.mapped{border-color:var(--accent-soft);color:var(--accent)}.map-sel.unmapped{border-color:var(--border);color:var(--text-dim)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.sd-ok{background:var(--accent)}.sd-warn{background:var(--amber)}.sd-err{background:var(--coral)}.sd-skip{background:var(--text-dim)}.sample-val{font-size:.72rem;color:var(--text-dim);font-family:var(--mono);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.warn{background:#f5c5420a;border:1px solid rgba(245,197,66,.12);border-left:3px solid var(--amber);border-radius:0 var(--radius-sm) var(--radius-sm)0;padding:10px 14px;margin-bottom:8px;font-size:.82rem;color:var(--text-muted);display:flex;gap:8px;align-items:flex-start}.warn svg{width:14px;height:14px;color:var(--amber);flex-shrink:0;margin-top:2px}.err-warn{border-left-color:var(--coral)}.err-warn svg{color:var(--coral)}.preview-wrap{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:14px}.preview-wrap::-webkit-scrollbar{height:5px}.preview-wrap::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}.prev-table{border-collapse:collapse;width:100%;min-width:600px}.prev-table th{padding:8px 10px;background:var(--card);border:1px solid var(--border);font-size:.72rem;font-weight:600;color:var(--accent);text-align:left;font-family:var(--mono);white-space:nowrap}.prev-table td{padding:6px 10px;border:1px solid var(--border);font-size:.76rem;color:var(--text-muted);font-family:var(--mono);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.prev-table tr:hover{background:var(--card)}.sdl-out{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px 16px;font-family:var(--mono);font-size:.78rem;color:var(--accent);line-height:1.7;white-space:pre;overflow-x:auto;position:relative;max-height:300px;overflow-y:auto}.cp{position:absolute;top:8px;right:8px;padding:6px 14px;border-radius:5px;border:1px solid var(--border);background:var(--card);color:var(--text-dim);font-size:.72rem;font-family:var(--font);cursor:pointer;z-index:2}.cp:hover{border-color:var(--accent);color:var(--accent)}.op-sel{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:12px}.op-btn{padding:8px 16px;border-radius:var(--radius-sm);border:1px solid var(--border);background:0 0;color:var(--text-dim);font-size:.82rem;font-family:var(--font);font-weight:500;cursor:pointer;transition:.12s}.op-btn:hover{border-color:var(--border);color:var(--text-muted)}.op-btn.on{border-color:var(--accent-soft);background:var(--accent-soft);color:var(--accent)}#results{display:none}.footer a:hover{color:var(--accent)}