*{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;flex-wrap:wrap}.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}@media (max-width: 700px){header{gap:10px 16px;padding:10px 14px}.brand{width:100%;font-size:16px}nav{flex:1 1 100%;gap:12px;flex-wrap:wrap;order:3}.user,table{font-size:13px}}.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-dfb6ea1c]{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:16px}.stat[data-v-dfb6ea1c]{text-align:center}.num[data-v-dfb6ea1c]{font-size:34px;font-weight:700}.lbl[data-v-dfb6ea1c]{color:#6b7280;font-size:13px;margin-top:4px}.charts[data-v-dfb6ea1c]{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:18px}.chart h3[data-v-dfb6ea1c]{margin:0 0 10px;font-size:15px;color:#374151}.cwrap[data-v-dfb6ea1c]{position:relative;height:260px}.charts .chart[data-v-dfb6ea1c]:first-child{grid-column:1 / -1}.err[data-v-dfb6ea1c]{color:#b91c1c}@media (max-width: 720px){.charts[data-v-dfb6ea1c]{grid-template-columns:1fr}}.err[data-v-5db62bab]{color:#b91c1c}.msg[data-v-5db62bab]{background:#ecfdf5;color:#065f46;padding:8px 12px;border-radius:8px}button[data-v-5db62bab]:not(.primary){border:1px solid #d1d5db;background:#fff;padding:8px 12px;border-radius:6px;cursor:pointer;font-size:13px}button[data-v-5db62bab]:disabled{opacity:.4;cursor:default}.acts[data-v-5db62bab]{display:flex;gap:6px}.acts button[data-v-5db62bab]{padding:5px 9px}.tscroll[data-v-5db62bab]{overflow-x:auto}.overlay[data-v-5db62bab]{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;padding:16px;z-index:50}.modal[data-v-5db62bab]{background:#fff;border-radius:12px;padding:22px;width:620px;max-width:100%;max-height:85vh;overflow:auto}.err[data-v-a8738d9d]{color:#b91c1c}.msg[data-v-a8738d9d]{background:#ecfdf5;color:#065f46;padding:10px 14px;border-radius:8px}.acts[data-v-a8738d9d]{display:flex;gap:6px}.acts button[data-v-a8738d9d]{border:1px solid #d1d5db;background:#fff;padding:4px 9px;border-radius:6px;cursor:pointer;font-size:12px}.err[data-v-450f0e3f]{color:#b91c1c}button[data-v-450f0e3f]{border:1px solid #d1d5db;background:#fff;padding:7px 12px;border-radius:6px;cursor:pointer}.acts[data-v-450f0e3f]{display:flex;gap:6px}.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-f41561b8]{max-width:900px;margin:24px auto;padding:0 14px}.lock[data-v-f41561b8]{max-width:380px}.lock input[data-v-f41561b8]{width:100%;margin:8px 0}.msg[data-v-f41561b8]{background:#ecfdf5;color:#065f46;padding:10px 14px;border-radius:8px}.err[data-v-f41561b8]{color:#b91c1c}button[data-v-f41561b8]{border:1px solid #d1d5db;background:#fff;padding:8px 14px;border-radius:6px;cursor:pointer}.logout[data-v-f41561b8]{border-color:#2f5496;color:#2f5496}.totals[data-v-f41561b8]{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px;margin-bottom:16px}.totals .t[data-v-f41561b8]{text-align:center}.totals .n[data-v-f41561b8]{font-size:30px;font-weight:700;color:#2f5496}.totals .l[data-v-f41561b8]{color:#6b7280;font-size:13px}.err[data-v-590a8205]{color:#b91c1c}button[data-v-590a8205]{border:1px solid #d1d5db;background:#fff;padding:7px 12px;border-radius:6px;cursor:pointer}.badge[data-v-590a8205]{padding:2px 8px;border-radius:999px;font-size:12px;background:#e5e7eb;color:#374151}.badge.ok[data-v-590a8205]{background:#dcfce7;color:#166534}.ghid[data-v-3b99556d]{max-width:800px}ol[data-v-3b99556d]{padding-left:20px;line-height:1.9}li[data-v-3b99556d]{margin-bottom:6px}.tip[data-v-3b99556d]{background:#ecfdf5;color:#065f46;padding:12px 14px;border-radius:8px}button[data-v-3b99556d]{border:1px solid #d1d5db;background:#fff;padding:8px 14px;border-radius:6px;cursor:pointer}@media print{.noprint[data-v-3b99556d]{display:none}}
