:root{--bg:#f7f9fd;--panel:#fff;--ink:#172033;--muted:#68758a;--line:#e8edf5;--primary:#5b7cfa;--teal:#19b8a2;--orange:#f5a742;--red:#ef6461}
*{box-sizing:border-box}body{margin:0;background:radial-gradient(circle at top left,#edf4ff 0,#f7f9fd 34%,#fff 100%);color:var(--ink);font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif}
.app-shell{display:flex;min-height:100vh}.sidebar{width:260px;background:rgba(255,255,255,.85);backdrop-filter:blur(18px);border-right:1px solid var(--line);padding:22px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:12px;font-weight:800;color:var(--ink);text-decoration:none;margin-bottom:24px}.brand-mark{display:grid;place-items:center;width:38px;height:38px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--teal));color:#fff}
.sidebar nav a{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;color:#40506a;text-decoration:none;margin:4px 0;transition:.18s}.sidebar nav a:hover{background:#eef4ff;color:var(--primary);transform:translateX(2px)}
.main{flex:1;min-width:0}.topbar{position:sticky;top:0;z-index:5;background:rgba(247,249,253,.82);backdrop-filter:blur(18px);border-bottom:1px solid var(--line);padding:18px 28px;display:flex;justify-content:space-between;align-items:center}.topbar h1{font-size:26px;margin:0;font-weight:800}.eyebrow{color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.08em}.content{padding:28px}
.cardx{background:var(--panel);border:1px solid var(--line);border-radius:20px;box-shadow:0 18px 45px rgba(30,45,80,.08);padding:20px}.stat{display:flex;justify-content:space-between;gap:14px;min-height:116px}.stat .num{font-size:31px;font-weight:850}.muted{color:var(--muted)}.badge.soft{background:#eef4ff;color:#4566d8;border:1px solid #dce7ff}.pill{display:inline-flex;align-items:center;border-radius:999px;padding:5px 10px;font-size:12px;font-weight:750}.pill-success{background:#e9f9f3;color:#0b8d6d}.pill-warning{background:#fff4df;color:#a96500}.pill-danger{background:#ffeceb;color:#b53632}.pill-primary,.pill-info{background:#eef4ff;color:#4566d8}.pill-secondary{background:#f0f2f6;color:#536070}.pill-dark{background:#e9ebf0;color:#252b35}
.btn-primary{background:linear-gradient(135deg,var(--primary),#7699ff);border:0;box-shadow:0 12px 24px rgba(91,124,250,.25)}.btn-success{background:linear-gradient(135deg,var(--teal),#4ccfbf);border:0}.form-control,.form-select{border-radius:13px;border:1px solid var(--line);padding:11px 13px}.table{vertical-align:middle}.table thead th{color:#69758a;font-size:12px;text-transform:uppercase;border-bottom:1px solid var(--line)}.table td{border-color:#edf1f7}
.dropzone{border:1.5px dashed #b9c9ec;border-radius:20px;background:#f8fbff;padding:28px;text-align:center;transition:.18s}.dropzone.drag{background:#eef6ff;border-color:var(--primary);transform:scale(1.01)}.progress{height:10px;border-radius:999px}.tabs .nav-link{border-radius:999px;color:#536070}.tabs .nav-link.active{background:#eef4ff;color:#4566d8;font-weight:800}.timeline{border-left:2px solid #e4ebf7;padding-left:18px}.timeline-item{position:relative;margin-bottom:16px}.timeline-item:before{content:"";position:absolute;left:-25px;top:5px;width:12px;height:12px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 5px #eef4ff}
.public-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(135deg,#f8fbff,#f6fff9)}.public-card{width:min(960px,100%);background:#fff;border:1px solid var(--line);border-radius:24px;box-shadow:0 24px 70px rgba(30,45,80,.12);padding:26px}
.toast-stack{position:fixed;right:20px;top:82px;z-index:99;display:grid;gap:10px}.toast-lite{background:#172033;color:#fff;padding:12px 14px;border-radius:14px;box-shadow:0 15px 36px rgba(0,0,0,.2)}
.document-table .doc-title{font-weight:700;color:#172033}.document-table .mapped-label{font-weight:700;color:#4566d8}.document-table .inline-editor{max-width:620px}
.preview-modal{border:0;border-radius:18px;overflow:hidden}.document-preview-frame{width:100%;height:78vh;border:0;background:#f8fafc}.preview-empty{min-height:360px;display:grid;place-items:center;text-align:center;padding:40px}
@media(max-width:900px){.app-shell{display:block}.sidebar{height:auto;width:auto;position:static;padding:14px}.sidebar nav{display:flex;overflow:auto;gap:8px}.sidebar nav a{white-space:nowrap}.topbar{padding:14px 16px}.content{padding:16px}.topbar h1{font-size:20px}}
