:root{--bg:#f4f6fb;--card:#fff;--ink:#1f2937;--muted:#6b7280;--brand:#1d4ed8;--brand-dark:#1e3a8a;--ok:#047857;--warn:#b45309;--danger:#b91c1c;--border:#e5e7eb}*{box-sizing:border-box}body,html{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:16px;line-height:1.5}a{color:var(--brand)}.topbar{background:var(--brand-dark);color:#fff;padding:12px 20px;display:flex;align-items:center;justify-content:space-between;gap:12px 16px;flex-wrap:wrap}.topbar .brand{font-weight:700;font-size:18px}.topbar .brand small{display:block;font-weight:400;opacity:.8;font-size:12px}.topbar .right{display:flex;align-items:center;gap:14px;font-size:14px;flex-wrap:wrap}.topbar a{color:#dbeafe;text-decoration:none;padding:6px 0}.topbar a:hover{text-decoration:underline}.container{max-width:1000px;margin:0 auto;padding:24px 20px}.narrow{max-width:460px}.card{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px;box-shadow:0 1px 3px rgba(0,0,0,.05)}h1{font-size:22px;margin:0 0 4px}h2{font-size:18px;margin:0 0 12px}.subtitle{color:var(--muted);margin:0 0 20px}label{display:block;font-weight:600;margin:16px 0 6px;font-size:14px}input,select{width:100%;min-height:44px;padding:10px 12px;border:1px solid var(--border);border-radius:8px;font-size:16px;background:#fff}input[type=file]{padding:8px}.btn{display:inline-block;background:var(--brand);color:#fff;border:none;border-radius:8px;padding:12px 18px;min-height:44px;font-size:16px;font-weight:600;cursor:pointer}.btn:hover{background:var(--brand-dark)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn.secondary{background:#fff;color:var(--brand);border:1px solid var(--brand)}.btn.ok{background:var(--ok)}.btn.small{padding:9px 12px;min-height:40px;font-size:14px}.btn.block{width:100%}.alert{padding:12px 14px;border-radius:8px;margin:14px 0;font-size:14px}.alert.error{background:#fef2f2;color:var(--danger);border:1px solid #fecaca}.alert.ok{background:#ecfdf5;color:var(--ok);border:1px solid #a7f3d0}.alert.info,.detected{background:#eff6ff;color:var(--brand-dark);border:1px solid #bfdbfe}.detected{font-size:20px;font-weight:700;border-radius:8px;padding:14px 16px;margin:12px 0;text-align:center}table{width:100%;border-collapse:collapse;font-size:14px}td,th{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle}th{background:#f9fafb;color:var(--muted);font-weight:600}tr:hover td{background:#fafbff}.badge{display:inline-block;padding:2px 9px;border-radius:999px;font-size:12px;font-weight:600}.badge.pending{background:#fff7ed;color:var(--warn);border:1px solid #fed7aa}.badge.printed{background:#ecfdf5;color:var(--ok);border:1px solid #a7f3d0}.badge.bn{background:#f3f4f6;color:#374151;border:1px solid #e5e7eb}.badge.color{background:#fdf4ff;color:#a21caf;border:1px solid #f5d0fe}.muted{color:var(--muted)}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.right-align{text-align:right}.mono{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.footer-note{color:var(--muted);font-size:12px;margin-top:24px;text-align:center}.dropzone{display:block;margin:8px 0 4px;padding:26px 16px;border:2px dashed #93c5fd;border-radius:12px;background:#f8fbff;text-align:center;cursor:pointer;transition:background .15s,border-color .15s}.dropzone:hover{background:#eff6ff}.dropzone.over{background:#e0edff;border-color:var(--brand)}.dz-title{font-size:17px;font-weight:700;color:var(--brand-dark)}.dz-sub{font-size:13px;color:var(--muted);margin-top:4px}.filelist{display:flex;flex-direction:column;gap:12px;margin-top:16px}.fileitem{border:1px solid var(--border);border-radius:12px;padding:14px;background:#fff}.fi-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.fi-name{font-weight:600;word-break:break-word;overflow-wrap:anywhere;line-height:1.3}.fi-remove{flex:0 0 auto;width:36px;height:36px;border-radius:8px;border:1px solid var(--border);background:#fff;color:var(--danger);font-size:16px;cursor:pointer}.fi-remove:hover{background:#fef2f2}.fi-status{font-size:14px;margin-top:8px}.fi-status.pages{font-weight:700;color:var(--brand-dark)}.fi-status.err{color:var(--danger)}.fi-controls{display:flex;gap:12px;margin-top:12px}.fi-field{flex:1 1;min-width:0}.fi-field label{margin:0 0 4px}.submit-row{margin-top:22px}@media (max-width:640px){.container{padding:16px 14px}.card{padding:18px 16px;border-radius:12px}h1{font-size:20px}.topbar{padding:10px 14px}.topbar .brand{font-size:16px}table{font-size:13px}td,th{padding:8px}.detected{font-size:18px}}