@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:wght@300;400;500;600;700;800&family=Newsreader:opsz,wght@6..72,300;400;500;600;700&display=swap";.upload-box{border:1px dashed var(--border);border-radius:var(--radius);padding:1.1rem;transition:border-color .2s,background .2s;background:#0a0c14a6}.upload-box--done{border-style:solid;border-color:#22c55e80;background:#22c55e14}.upload-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;color:var(--text-muted);margin-bottom:.75rem}.dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.45rem;padding:1.6rem .75rem;cursor:pointer;border-radius:calc(var(--radius) - 2px);border:1px dashed rgba(255,255,255,.08);transition:background .15s,border-color .15s;text-align:center;background:#ffffff05}.dropzone:hover{background:#5eead414;border-color:#5eead459}.dropzone-icon{font-size:2.1rem}.dropzone-text{font-size:.9rem;color:var(--primary);font-weight:600}.dropzone-hint{font-size:.75rem;color:var(--text-muted)}.upload-uploading{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.9rem}.upload-success{display:flex;align-items:center;gap:.75rem;padding:.5rem .6rem;border-radius:12px;background:#22c55e14;border:1px solid rgba(34,197,94,.3)}.file-icon{font-size:1.2rem}.file-name{flex:1;font-size:.9rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:#bbf7d0}.upload-error{margin-top:.6rem;font-size:.8rem;color:#fecaca}.hidden-input{display:none}.spinner--dark{border-color:#ffffff40;border-top-color:var(--primary)}.audit-dropdown-wrapper{display:flex;flex-direction:column;gap:.6rem}.dropdown-label{font-size:.85rem;font-weight:600;color:var(--text)}.audit-select{width:100%;max-width:420px;padding:.7rem 1rem;border:1px solid var(--border);border-radius:12px;font-size:.95rem;background:#0a0c14cc;color:var(--text);cursor:pointer;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto;transition:border-color .15s,box-shadow .15s}.audit-select:focus{outline:none;border-color:#5eead4b3;box-shadow:0 0 0 3px #5eead433}.audit-select:disabled{background:#0f121c99;color:var(--text-muted);cursor:not-allowed}.dropdown-hint{font-size:.8rem;color:var(--text-muted);font-style:italic}.vp-loading{display:flex;align-items:center;gap:.6rem;color:var(--text-muted);font-size:.95rem;padding:.5rem 0}.vp-success{display:flex;align-items:flex-start;gap:.75rem;background:#22c55e1f;border:1px solid rgba(34,197,94,.35);border-radius:12px;padding:1rem 1.25rem}.vp-success strong{color:#bbf7d0}.vp-sub{font-size:.85rem;color:#86efac;margin-top:.25rem}.vp-icon{font-size:1.3rem;flex-shrink:0;margin-top:.1rem}.vp-error-wrap{background:#f871711a;border:1px solid rgba(248,113,113,.35);border-radius:var(--radius);padding:1.25rem}.vp-error-header{display:flex;align-items:center;gap:.6rem;margin-bottom:1rem;color:#fecaca}.vp-files-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.25rem}@media (max-width: 680px){.vp-files-grid{grid-template-columns:1fr}}.missing-list,.file-ok{background:#0a0c14bf;border:1px solid rgba(248,113,113,.35);border-radius:12px;padding:.75rem 1rem}.file-ok{border-color:#22c55e59}.missing-filename{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;margin-bottom:.5rem;flex-wrap:wrap}.fn-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px}.missing-badge{background:#f8717133;color:#fecaca;font-size:.7rem;padding:.15rem .45rem;border-radius:999px;font-weight:600;border:1px solid rgba(248,113,113,.4)}.ok-badge{background:#22c55e33;color:#bbf7d0;font-size:.7rem;padding:.15rem .45rem;border-radius:999px;font-weight:600;border:1px solid rgba(34,197,94,.4)}.missing-list ul{list-style:none}.missing-list li{font-size:.85rem;color:#fecaca;padding:.15rem 0}.file-ok-msg{font-size:.85rem;color:#bbf7d0}.vp-required-section{margin-top:.25rem}.vp-required-title{font-size:.8rem;font-weight:600;color:var(--text-muted);margin-bottom:.5rem}.vp-tag-list{display:flex;flex-wrap:wrap;gap:.4rem}.vp-tag{font-size:.75rem;padding:.2rem .55rem;border-radius:999px;font-weight:500}.vp-tag--ok{background:#22c55e33;color:#bbf7d0}.vp-tag--missing{background:#f8717133;color:#fecaca}.vp-required-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}@media (max-width: 680px){.vp-required-row{grid-template-columns:1fr}}.results-card{padding:1.8rem}.results-header{margin-bottom:1.25rem}.results-title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:.45rem}.results-title-row h2{font-size:1.15rem;font-weight:700}.results-meta{display:flex;align-items:center;gap:.75rem;font-size:.82rem;color:var(--text-muted);flex-wrap:wrap}.results-meta strong{color:var(--text)}.btn-export{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem 1.1rem;border-radius:999px;border:1px solid rgba(94,234,212,.5);background:#5eead41a;color:var(--primary);font-size:.88rem;font-weight:600;cursor:pointer;transition:background .15s,box-shadow .15s,transform .15s;white-space:nowrap}.btn-export:hover:not(:disabled){background:#5eead433;box-shadow:0 8px 20px #5eead433;transform:translateY(-1px)}.btn-export:disabled{opacity:.55;cursor:not-allowed}.summary-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem;margin-bottom:1.5rem}@media (max-width: 740px){.summary-grid{grid-template-columns:1fr 1fr}}.summary-tile{border-radius:14px;padding:.95rem 1rem;text-align:center;border:1px solid rgba(255,255,255,.08);background:#0a0c14bf}.tile-value{font-size:1.8rem;font-weight:700;line-height:1}.tile-label{font-size:.75rem;margin-top:.35rem;font-weight:600;color:var(--text-muted)}.summary-tile--blue{color:#bae6fd;border-color:#38bdf859}.summary-tile--red{color:#fecaca;border-color:#f8717159}.summary-tile--green{color:#bbf7d0;border-color:#22c55e59}.summary-tile--orange{color:#fde68a;border-color:#f59e0b59}.mismatch-section{margin-top:.5rem}.mismatch-toolbar{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.75rem;margin-bottom:.85rem}.mismatch-toolbar h3{font-size:.95rem;font-weight:600}.search-input{padding:.45rem .8rem;border:1px solid var(--border);border-radius:12px;font-size:.85rem;width:230px;background:#0a0c14bf;color:var(--text);transition:border-color .15s,box-shadow .15s}.search-input:focus{outline:none;border-color:#5eead4b3;box-shadow:0 0 0 3px #5eead433}.no-results{color:var(--text-muted);font-size:.9rem;padding:.5rem 0}.flat-table-wrap{overflow-x:auto;border-radius:12px;border:1px solid rgba(248,113,113,.25);background:#0a0c1480}.flat-diff-table{width:100%;border-collapse:collapse;font-size:.85rem}.flat-diff-table thead tr.col-headers{background:#f871712e}.flat-diff-table th{text-align:left;padding:.65rem .9rem;font-weight:700;font-size:.78rem;letter-spacing:.05em;text-transform:uppercase;white-space:nowrap;color:#fca5a5;border-bottom:1px solid rgba(248,113,113,.35)}.flat-diff-table thead tr.filter-row th{background:#0a0c1499;padding:.4rem .6rem;border-bottom:2px solid rgba(248,113,113,.3)}.col-filter-input,.col-filter-select{width:100%;padding:.3rem .55rem;border-radius:6px;border:1px solid rgba(255,255,255,.1);background:#ffffff0f;color:var(--text);font-size:.78rem;outline:none;transition:border-color .15s,box-shadow .15s}.col-filter-input:focus,.col-filter-select:focus{border-color:#5eead480;box-shadow:0 0 0 2px #5eead426}.col-filter-select option{background:#1a1f2e}.flat-diff-table td{padding:.5rem .9rem;border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.flat-diff-table tr.group-first td{border-top:1px solid rgba(248,113,113,.2);padding-top:.65rem}.flat-diff-table tr.group-first:first-child td{border-top:none}.flat-diff-table tbody tr:hover td{background:#ffffff08}.col-empid{width:15%;vertical-align:top}.col-count{width:10%;vertical-align:top;text-align:center}.col-field{width:20%;font-weight:600;color:var(--text);white-space:nowrap}.col-recon,.col-otbi{width:27%}.person-number-text{font-weight:700;font-size:.88rem;color:var(--text)}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:1.8rem;height:1.8rem;border-radius:999px;background:#f8717133;border:1px solid rgba(248,113,113,.45);color:#fecaca;font-size:.78rem;font-weight:700}.no-results-cell{text-align:center;color:var(--text-muted);padding:1.5rem!important;font-size:.88rem}.filter-active-badge{font-size:.72rem;font-weight:500;background:#5eead426;border:1px solid rgba(94,234,212,.35);color:var(--primary);padding:.1rem .55rem;border-radius:999px;margin-left:.75rem;vertical-align:middle}.btn-clear-filters{background:none;border:1px solid rgba(248,113,113,.4);color:#fca5a5;border-radius:999px;padding:.25rem .75rem;font-size:.78rem;cursor:pointer;transition:background .15s}.btn-clear-filters:hover{background:#f871711f}.mismatch-list{display:flex;flex-direction:column;gap:.6rem}.emp-id-badge{display:flex;flex-direction:column;gap:.2rem}.emp-id-badge .emp-diff-count{font-size:.72rem;font-weight:500;color:#fecaca;background:#f8717133;padding:.1rem .45rem;border-radius:999px;border:1px solid rgba(248,113,113,.4);align-self:flex-start;white-space:nowrap}.mismatch-row{border:1px solid var(--mismatch-border);border-radius:14px;background:var(--mismatch-bg);overflow:hidden}.mismatch-toggle{width:100%;background:none;border:none;cursor:pointer;padding:.85rem 1rem;display:flex;align-items:center;gap:.75rem;text-align:left;transition:background .15s}.mismatch-toggle:hover{background:#f871711f}.emp-id{font-weight:700;font-size:.9rem;color:var(--text);flex-shrink:0}.mismatch-count{font-size:.8rem;color:#fecaca;background:#f8717133;padding:.15rem .55rem;border-radius:999px;border:1px solid rgba(248,113,113,.4)}.chevron{margin-left:auto;font-size:.75rem;color:var(--text-muted)}.mismatch-detail{padding:0 1rem 1rem;overflow-x:auto}.diff-table{width:100%;border-collapse:collapse;font-size:.85rem}.diff-table th{text-align:left;padding:.55rem .75rem;background:#f8717126;border-bottom:1px solid rgba(248,113,113,.3);font-weight:600;font-size:.78rem;white-space:nowrap}.diff-table td{padding:.5rem .75rem;border-bottom:1px solid rgba(248,113,113,.15);vertical-align:top}.diff-row:last-child td{border-bottom:none}.col-name{font-weight:600;color:var(--text);white-space:nowrap}.val-chip{display:inline-block;padding:.2rem .6rem;border-radius:8px;font-size:.82rem;word-break:break-word;border:1px solid rgba(255,255,255,.08)}.val-chip--1{background:#38bdf826;color:#bae6fd}.val-chip--2{background:#f472b626;color:#fbcfe8}.empty-val{color:#94a3b8;font-style:italic;font-size:.78rem}.orphan-section{margin-top:1.5rem;display:flex;flex-direction:column;gap:.75rem}.orphan-box{border-radius:var(--radius);border:1px solid;overflow:hidden;background:#0a0c14a6}.orphan-box--orange{border-color:#f59e0b66}.orphan-box--purple{border-color:#818cf866}.orphan-toggle{width:100%;background:none;border:none;cursor:pointer;padding:.85rem 1rem;display:flex;align-items:center;gap:.75rem;font-size:.88rem;font-weight:600;text-align:left;color:var(--text)}.orphan-count{background:#ffffff0f;border:1px solid currentColor;padding:.1rem .5rem;border-radius:999px;font-size:.75rem}.orphan-ids{padding:.5rem 1rem 1rem;display:flex;flex-wrap:wrap;gap:.4rem}.orphan-id-chip{font-size:.8rem;background:#ffffff0f;border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:.15rem .5rem;color:var(--text)}.app-shell{display:flex;flex-direction:column;min-height:100vh}.app-header{background:#0b0d13bf;border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);position:sticky;top:0;z-index:100}.header-inner{width:100%;max-width:1100px;margin:0 auto;padding:.8rem 1.5rem;display:flex;align-items:center;justify-content:space-between}.header-logo{display:flex;align-items:center;gap:.75rem}.logo-icon{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:12px;background:linear-gradient(135deg,#5eead4f2,#6366f1d9);box-shadow:0 12px 28px #5eead459;font-size:1.1rem}.logo-text{font-size:1.05rem;font-weight:600;letter-spacing:.01em;font-family:Newsreader,serif}.logo-stack{display:flex;flex-direction:column;gap:0}.logo-sub{font-size:.68rem;color:var(--text-muted);letter-spacing:.06em;text-transform:uppercase;font-family:sans-serif;font-weight:400}.app-main{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:2.5rem 1.5rem 3.5rem;display:flex;flex-direction:column;gap:1.75rem}.app-hero{display:grid;grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:2rem;align-items:stretch}@media (max-width: 900px){.app-hero{grid-template-columns:1fr}}.hero-copy{display:flex;flex-direction:column;gap:1rem}.hero-kicker{text-transform:uppercase;letter-spacing:.35em;font-size:.65rem;color:var(--text-muted)}.hero-title{font-size:clamp(2.1rem,4.5vw,3.4rem);line-height:1.05;letter-spacing:-.02em;font-family:Newsreader,serif}.hero-sub{color:var(--text-muted);font-size:1rem;max-width:36rem}.hero-pills{display:flex;flex-wrap:wrap;gap:.6rem}.hero-pill{font-size:.75rem;padding:.35rem .7rem;border-radius:999px;border:1px solid var(--border);background:#ffffff0a;color:var(--text)}.hero-panel{background:linear-gradient(140deg,#22d3ee14,#6366f11f);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.6rem;box-shadow:var(--shadow-soft);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.hero-panel-inner{display:flex;flex-direction:column;gap:1rem}.hero-stat{padding:1rem 1.1rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#080a1273}.stat-label{display:block;font-size:.7rem;text-transform:uppercase;letter-spacing:.2em;color:var(--text-muted);margin-bottom:.35rem}.stat-value{font-size:.95rem;font-weight:600;color:var(--text)}.hero-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.75rem}.hero-mini{padding:.75rem .85rem;border-radius:12px;border:1px solid rgba(255,255,255,.08);background:#090b148c}.mini-label{font-size:.7rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.18em}.mini-value{display:block;margin-top:.35rem;font-size:.9rem;font-weight:600;color:var(--text)}.app-footer{text-align:center;padding:1.5rem 1rem 2rem;font-size:.8rem;color:var(--text-muted);border-top:1px solid var(--border)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft);padding:1.6rem;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.step-header{display:flex;align-items:center;gap:.85rem;margin-bottom:1.1rem}.step-header h2{font-size:1.05rem;font-weight:600}.step-badge{background:linear-gradient(135deg,#5eead4e6,#3b82f6e6);color:#0b1221;width:30px;height:30px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:700;flex-shrink:0;box-shadow:0 10px 25px #5eead44d}.step-disabled{opacity:.55;pointer-events:none}.step-description{color:var(--text-muted);margin-bottom:1.25rem;font-size:.95rem}.upload-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:1.25rem}@media (max-width: 700px){.upload-grid{grid-template-columns:1fr}}.btn{display:inline-flex;align-items:center;gap:.45rem;border:none;border-radius:999px;cursor:pointer;font-size:.9rem;font-weight:600;padding:.55rem 1.2rem;transition:transform .15s,box-shadow .15s,opacity .15s}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,#5eead4f2,#3b82f6e6);color:#041016;box-shadow:0 16px 30px #5eead440}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 20px 38px #5eead459}.btn-ghost{background:#ffffff0f;color:var(--text);border:1px solid rgba(255,255,255,.12)}.btn-ghost:hover{background:#ffffff1f}.btn-outline{background:transparent;color:var(--text);border:1px solid rgba(255,255,255,.16)}.btn-outline:hover:not(:disabled){background:#ffffff14}.btn-sm{padding:.35rem .85rem;font-size:.8rem}.btn-lg{padding:.8rem 1.6rem;font-size:1rem}.btn-danger{background:#f8717126;color:#fecaca;border:1px solid rgba(248,113,113,.35)}.btn-danger:hover:not(:disabled){background:#f8717138}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.35);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.alert{padding:.85rem 1rem;border-radius:12px;display:flex;align-items:flex-start;gap:.6rem;font-size:.9rem}.alert-error{background:#f871711f;border:1px solid rgba(248,113,113,.35);color:#fecaca}.alert-success{background:#22c55e1f;border:1px solid rgba(34,197,94,.35);color:#bbf7d0}.alert-warning{background:#f59e0b1f;border:1px solid rgba(245,158,11,.35);color:#fde68a}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--primary: #5eead4;--primary-strong: #2dd4bf;--primary-dark: #0ea5a4;--success: #22c55e;--error: #f87171;--warning: #f59e0b;--bg: #0b0c12;--surface: rgba(17, 19, 28, .78);--surface-strong: #121521;--border: rgba(148, 163, 184, .18);--text: #e5e7eb;--text-muted: #9aa3b2;--mismatch-bg: rgba(248, 113, 113, .1);--mismatch-border: rgba(248, 113, 113, .35);--radius: 14px;--radius-lg: 18px;--shadow: 0 24px 80px rgba(5, 7, 15, .55);--shadow-soft: 0 10px 35px rgba(7, 9, 20, .4)}body{font-family:Bricolage Grotesque,sans-serif;background:radial-gradient(1200px at 10% -10%,rgba(34,211,238,.18),transparent 60%),radial-gradient(900px at 90% 0%,rgba(99,102,241,.18),transparent 55%),var(--bg);color:var(--text);line-height:1.6;min-height:100vh;color-scheme:dark}::selection{background:#5eead440;color:var(--text)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0f111a99}::-webkit-scrollbar-thumb{background:#94a3b866;border-radius:10px}
