*{box-sizing:border-box}body{margin:0;font-family:system-ui,sans-serif;background:#f4f6fb;color:#1f2937}header{display:flex;align-items:center;gap:24px;padding:12px 24px;background:#2f5496;color:#fff}.brand{font-weight:700;font-size:18px}.brand span{opacity:.85;font-weight:400}nav{display:flex;gap:16px;flex:1}nav a{color:#dbe4ff;text-decoration:none;font-weight:500}nav a.router-link-active{color:#fff;border-bottom:2px solid #fff}.user{display:flex;align-items:center;gap:10px;font-size:14px}.user button{background:#1e3a6b;color:#fff;border:0;padding:6px 12px;border-radius:6px;cursor:pointer}main{max-width:1100px;margin:24px auto;padding:0 16px}.card{background:#fff;border-radius:10px;padding:20px;box-shadow:0 1px 3px #00000014;margin-bottom:18px}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:9px 10px;border-bottom:1px solid #eef0f5;font-size:14px}th{color:#6b7280;font-weight:600}input,select{padding:8px 10px;border:1px solid #d1d5db;border-radius:6px;font-size:14px}button.primary{background:#2f5496;color:#fff;border:0;padding:9px 16px;border-radius:6px;cursor:pointer;font-weight:600}.row{display:flex;gap:10px;flex-wrap:wrap;align-items:center}.badge{padding:2px 8px;border-radius:999px;font-size:12px}.badge.ok{background:#dcfce7;color:#166534}.badge.late{background:#fee2e2;color:#991b1b}.login-wrap[data-v-b88ff47a]{min-height:100vh;display:flex;align-items:center;justify-content:center}.login[data-v-b88ff47a]{width:360px}.login h1[data-v-b88ff47a]{margin:0 0 4px}.sub[data-v-b88ff47a]{color:#6b7280;font-size:13px;margin-top:0}label[data-v-b88ff47a]{display:block;margin:12px 0 4px;font-size:13px;font-weight:600}input[data-v-b88ff47a]{width:100%}button.primary[data-v-b88ff47a]{width:100%;margin-top:18px}.err[data-v-b88ff47a]{color:#b91c1c;font-size:13px}.portal-link[data-v-b88ff47a]{display:block;text-align:center;margin-top:14px;color:#2f5496;font-size:13px}.grid[data-v-4608e21d]{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px}.stat[data-v-4608e21d]{text-align:center}.num[data-v-4608e21d]{font-size:36px;font-weight:700}.lbl[data-v-4608e21d]{color:#6b7280;font-size:13px;margin-top:4px}.err[data-v-4608e21d],.err[data-v-19dbf477]{color:#b91c1c}button[data-v-19dbf477]:not(.primary){border:1px solid #d1d5db;background:#fff;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:13px}.err[data-v-93fb9b45]{color:#b91c1c}.msg[data-v-93fb9b45]{background:#ecfdf5;color:#065f46;padding:10px 14px;border-radius:8px}.acts[data-v-93fb9b45]{display:flex;gap:6px}.acts button[data-v-93fb9b45]{border:1px solid #d1d5db;background:#fff;padding:4px 9px;border-radius:6px;cursor:pointer;font-size:12px}.err[data-v-ec1bfae8]{color:#b91c1c}button[data-v-ec1bfae8]{border:1px solid #d1d5db;background:#fff;padding:7px 12px;border-radius:6px;cursor:pointer}.portal[data-v-9a54650f]{max-width:860px;margin:24px auto;padding:0 14px}.phead[data-v-9a54650f]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.logo[data-v-9a54650f]{font-size:22px;font-weight:700;color:#2f5496}.who[data-v-9a54650f]{display:flex;align-items:center;gap:12px}.who span[data-v-9a54650f]{font-size:14px;color:#374151}.logout[data-v-9a54650f]{background:#2f5496;color:#fff;border:0;border-radius:6px;padding:8px 14px;cursor:pointer;font-weight:600}.bell[data-v-9a54650f]{background:#fff;color:#2f5496;border:1px solid #2f5496;border-radius:6px;padding:8px 12px;cursor:pointer;font-weight:600}.bell[data-v-9a54650f]:disabled{background:#ecfdf5;color:#16a34a;border-color:#16a34a;cursor:default}.staff[data-v-9a54650f]{text-decoration:none;color:#2f5496}.login[data-v-9a54650f]{max-width:360px;margin:30px auto;text-align:center}.login input[data-v-9a54650f]{width:100%;margin:6px 0}.login .primary[data-v-9a54650f]{width:100%;margin-top:10px}.hint[data-v-9a54650f]{color:#6b7280;font-size:13px}.tabs[data-v-9a54650f]{display:flex;gap:8px;margin-bottom:14px;flex-wrap:wrap}.tabs button[data-v-9a54650f]{border:1px solid #d1d5db;background:#fff;padding:8px 14px;border-radius:8px;cursor:pointer;font-size:14px}.tabs button.on[data-v-9a54650f]{background:#2f5496;color:#fff;border-color:#2f5496}.search[data-v-9a54650f]{display:flex;gap:14px;align-items:center;margin-bottom:8px;flex-wrap:wrap}.search input[type=text][data-v-9a54650f],.search input[data-v-9a54650f]:not([type]){flex:1;min-width:220px;padding:11px;font-size:15px}.chk[data-v-9a54650f]{font-size:14px;color:#374151;display:flex;align-items:center;gap:6px}.count[data-v-9a54650f]{color:#6b7280;font-size:13px;margin:4px 0 12px}.grid[data-v-9a54650f]{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.book[data-v-9a54650f]{display:flex;gap:10px;background:#fff;border-radius:10px;padding:12px;box-shadow:0 1px 3px #00000014}.cover[data-v-9a54650f]{width:44px;height:60px;background:#2f5496;color:#fff;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:700;flex-shrink:0}.info[data-v-9a54650f]{display:flex;flex-direction:column;gap:2px}.info span[data-v-9a54650f]{font-size:12px;color:#6b7280}.av.y[data-v-9a54650f]{color:#16a34a;font-weight:600}.av.n[data-v-9a54650f]{color:#dc2626}.rsv[data-v-9a54650f]{margin-top:6px;align-self:flex-start;background:#f59e0b;color:#fff;border:0;padding:4px 10px;border-radius:6px;cursor:pointer;font-size:12px}.msg[data-v-9a54650f]{background:#ecfdf5;color:#065f46;padding:10px 14px;border-radius:8px}.empty[data-v-9a54650f]{color:#9ca3af;text-align:center}.err[data-v-9a54650f]{color:#b91c1c;font-size:13px}.badge[data-v-9a54650f]{padding:2px 8px;border-radius:999px;font-size:12px}.badge.ok[data-v-9a54650f]{background:#dcfce7;color:#166534}.badge.late[data-v-9a54650f]{background:#fee2e2;color:#991b1b}table[data-v-9a54650f]{width:100%;border-collapse:collapse}th[data-v-9a54650f],td[data-v-9a54650f]{text-align:left;padding:9px 10px;border-bottom:1px solid #eef0f5;font-size:14px}th[data-v-9a54650f]{color:#6b7280;font-weight:600}.sa[data-v-3f812215]{max-width:900px;margin:24px auto;padding:0 14px}.lock[data-v-3f812215]{max-width:380px}.lock input[data-v-3f812215]{width:100%;margin:8px 0}.msg[data-v-3f812215]{background:#ecfdf5;color:#065f46;padding:10px 14px;border-radius:8px}.err[data-v-3f812215]{color:#b91c1c}button[data-v-3f812215]{border:1px solid #d1d5db;background:#fff;padding:8px 14px;border-radius:6px;cursor:pointer}.logout[data-v-3f812215]{border-color:#2f5496;color:#2f5496}
