:root{--blue:#1a6ec0;--blue-dark:#155a9e;--blue-soft:#e8f1fb;--green:#2e9e4f;--green-soft:#e6f5ec;--orange:#f5a200;--orange-soft:#fdf1d8;--red:#d64545;--red-soft:#fbeaea;--ink:#1f2a37;--muted:#6b7785;--line:#e5e9ef;--paper:#f6f8fb;--card:#fff;--shadow:0 1px 2px #1f2a370f, 0 6px 20px #1f2a370f;--radius:16px}*{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--paper);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Nunito,system-ui,sans-serif;line-height:1.45}h1,h2,h3,h4,.display{margin:0;font-family:"Baloo 2",system-ui,sans-serif}.mono{letter-spacing:-.02em;font-family:Spline Sans Mono,ui-monospace,monospace}button{cursor:pointer;font-family:inherit}input,select{font-family:inherit;font-size:15px}a{color:var(--blue)}.app{min-height:100vh;display:flex}.sidebar{background:var(--card);border-right:1px solid var(--line);flex-direction:column;flex-shrink:0;width:248px;height:100vh;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;padding:22px 20px 16px;display:flex}.brand .mark{background:linear-gradient(135deg,var(--blue),#2f8fdc);color:#fff;border-radius:12px;flex-shrink:0;place-items:center;width:42px;height:42px;font-size:22px;display:grid;box-shadow:0 4px 12px #1a6ec059}.brand b{font-family:"Baloo 2";font-size:18px;line-height:1.05;display:block}.brand span{color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:700}.nav{flex-direction:column;flex:1;gap:2px;padding:6px 12px;display:flex;overflow:auto}.nav button{text-align:left;width:100%;color:var(--muted);background:0 0;border:0;border-radius:12px;align-items:center;gap:12px;padding:11px 14px;font-size:15px;font-weight:700;transition:all .15s;display:flex}.nav button .ic{text-align:center;width:22px;font-size:18px}.nav button:hover{background:var(--paper);color:var(--ink)}.nav button.active{background:var(--blue-soft);color:var(--blue-dark)}.nav-foot{border-top:1px solid var(--line);color:var(--muted);padding:14px 18px;font-size:12px}.main{flex-direction:column;flex:1;min-width:0;display:flex}.topbar{background:var(--card);border-bottom:1px solid var(--line);z-index:20;align-items:center;gap:10px;padding:12px 16px;display:none;position:sticky;top:0}.content{flex:1;width:100%;max-width:1100px;margin:0 auto;padding:26px 30px 90px}.page-head{margin-bottom:20px}.page-head h2{font-size:26px;font-weight:700}.page-head p{color:var(--muted);margin:4px 0 0;font-size:14px;font-weight:600}.botnav{display:none}.grid{gap:16px;display:grid}.cards{grid-template-columns:repeat(auto-fit,minmax(160px,1fr))}.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow)}.pad{padding:20px}.stat{border-radius:var(--radius);background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);padding:18px 20px;position:relative;overflow:hidden}.stat .k{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:13px;font-weight:800}.stat .v{margin-top:4px;font-family:"Baloo 2";font-size:34px;font-weight:800;line-height:1.1}.stat .bar{width:5px;position:absolute;top:0;bottom:0;left:0}.stat.blue .bar{background:var(--blue)}.stat.green .bar{background:var(--green)}.stat.orange .bar{background:var(--orange)}.stat.red .bar{background:var(--red)}.stat.grey .bar{background:var(--muted)}.btn{background:var(--blue);color:#fff;border:1px solid #0000;border-radius:12px;justify-content:center;align-items:center;gap:8px;padding:11px 18px;font-size:15px;font-weight:800;transition:all .15s;display:inline-flex}.btn:hover{background:var(--blue-dark)}.btn.sec{background:var(--card);color:var(--ink);border-color:var(--line)}.btn.sec:hover{background:var(--paper)}.btn.green{background:var(--green)}.btn.green:hover{filter:brightness(.94)}.btn.warn{background:var(--orange);color:#3a2c00}.btn.warn:hover{filter:brightness(.96)}.btn.danger{background:var(--red)}.btn.danger:hover{filter:brightness(.94)}.btn.sm{border-radius:9px;padding:7px 12px;font-size:13px}.btn.block{width:100%}.btn:disabled{opacity:.5;cursor:not-allowed}.field{margin-bottom:14px}.field label{color:var(--ink);margin-bottom:6px;font-size:13px;font-weight:800;display:block}.field input,.field select{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:11px;outline:none;padding:11px 13px;transition:all .15s}.field input:focus,.field select:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.row{flex-wrap:wrap;gap:12px;display:flex}.row>*{flex:1;min-width:140px}.badge{border-radius:999px;align-items:center;gap:5px;padding:3px 10px;font-size:12px;font-weight:800;display:inline-flex}.b-green{background:var(--green-soft);color:#1d7a39}.b-blue{background:var(--blue-soft);color:var(--blue-dark)}.b-orange{background:var(--orange-soft);color:#9a6800}.b-red{background:var(--red-soft);color:#a82f2f}.b-grey{color:var(--muted);background:#eef1f5}.idtag{border:1px solid var(--line);background:#f1f4f8;border-radius:7px;padding:2px 8px;font-size:13px;font-weight:600;display:inline-block}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:.04em;color:var(--muted);border-bottom:2px solid var(--line);padding:10px 12px;font-size:12px;font-weight:800}td{border-bottom:1px solid var(--line);vertical-align:middle;padding:11px 12px;font-size:14px;font-weight:600}tr:hover td{background:#fafbfd}.t-wrap{border-radius:var(--radius);border:1px solid var(--line);background:var(--card);overflow:auto}.actions{flex-wrap:wrap;gap:6px;display:flex}.toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:16px;display:flex}.search{flex:1;min-width:200px;position:relative}.search input{border:1px solid var(--line);background:#fff;border-radius:12px;outline:none;width:100%;padding:11px 14px 11px 38px}.search input:focus{border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}.search .si{color:var(--muted);position:absolute;top:50%;left:13px;transform:translateY(-50%)}.empty{text-align:center;color:var(--muted);padding:54px 20px}.empty .e-ic{margin-bottom:10px;font-size:46px}.empty h3{color:var(--ink);margin-bottom:6px;font-family:"Baloo 2";font-size:20px}.scandesk{grid-template-columns:1fr 1fr;align-items:start;gap:18px;display:grid}.scanbox{padding:24px}.scanbox .scan-in{border:2px solid var(--blue);letter-spacing:.04em;text-align:center;text-transform:uppercase;background:#fff;border-radius:14px;outline:none;width:100%;padding:16px 18px;font-family:Spline Sans Mono;font-size:20px;font-weight:600}.scanbox .scan-in:focus{box-shadow:0 0 0 4px var(--blue-soft)}.scan-hint{text-align:center;color:var(--muted);margin-top:10px;font-size:13px;font-weight:700}#reader{border-radius:14px;margin-top:14px;overflow:hidden}#reader:empty{display:none}.bookcard{min-height:200px;padding:22px}.bookcard .bc-title{font-family:"Baloo 2";font-size:21px;font-weight:700;line-height:1.15}.bookcard .bc-meta{color:var(--muted);margin-top:3px;font-size:14px;font-weight:700}.kv{border-bottom:1px dashed var(--line);justify-content:space-between;gap:10px;padding:8px 0;font-size:14px;display:flex}.kv .k{color:var(--muted);font-weight:700}.kv .v{text-align:right;font-weight:800}.placeholder-card{text-align:center;color:var(--muted);place-items:center;padding:30px;display:grid}.placeholder-card .pc-ic{opacity:.5;margin-bottom:8px;font-size:48px}.overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#141e2d80;place-items:center;padding:18px;display:grid;position:fixed;inset:0}.modal{background:var(--card);border-radius:18px;width:100%;max-width:480px;max-height:90vh;overflow:auto;box-shadow:0 24px 60px #00000040}.modal-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-head h3{font-size:20px;font-weight:700}.modal-body{padding:22px}.x{color:var(--muted);background:0 0;border:0;border-radius:8px;padding:4px 8px;font-size:24px;line-height:1}.x:hover{background:var(--paper);color:var(--ink)}.toasts{z-index:200;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--ink);color:#fff;border-radius:12px;align-items:center;gap:10px;max-width:340px;padding:13px 18px;font-size:14px;font-weight:700;animation:.25s slidein;display:flex;box-shadow:0 10px 30px #00000040}.toast.ok{background:var(--green)}.toast.err{background:var(--red)}.toast.warn{background:var(--orange);color:#3a2c00}@keyframes slidein{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:none}}.label-grid{flex-wrap:wrap;gap:12px;display:flex}.qlabel{text-align:center;page-break-inside:avoid;break-inside:avoid;background:#fff;border:1px dashed #b8c2cf;border-radius:12px;flex-direction:column;align-items:center;gap:6px;width:200px;padding:12px;display:flex}.qlabel .ql-brand{color:var(--blue);font-family:"Baloo 2";font-size:13px;font-weight:800}.qlabel .ql-qr{place-items:center;display:grid}.qlabel .ql-qr img,.qlabel .ql-qr canvas{display:block}.qlabel .ql-id{letter-spacing:.02em;font-family:Spline Sans Mono;font-size:15px;font-weight:600}.qlabel .ql-title{color:var(--muted);height:26px;font-size:11px;font-weight:700;line-height:1.2;overflow:hidden}.loading{min-height:60vh;color:var(--muted);place-items:center;font-weight:700;display:grid}.spin{border:3px solid var(--line);border-top-color:var(--blue);border-radius:50%;width:30px;height:30px;margin-bottom:12px;animation:.8s linear infinite rot}@keyframes rot{to{transform:rotate(360deg)}}.note{background:var(--orange-soft);color:#7a5500;border:1px solid #f0d690;border-radius:12px;align-items:flex-start;gap:8px;padding:12px 14px;font-size:13px;font-weight:700;display:flex}@media (width<=820px){.sidebar{display:none}.topbar{display:flex}.content{padding:18px 16px 96px}.scandesk{grid-template-columns:1fr}.botnav{background:var(--card);border-top:1px solid var(--line);z-index:50;justify-content:space-around;padding:6px 4px;display:flex;position:fixed;bottom:0;left:0;right:0}.botnav button{color:var(--muted);background:0 0;border:0;border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:6px 8px;font-size:10px;font-weight:800;display:flex}.botnav button .ic{font-size:19px}.botnav button.active{color:var(--blue)}.page-head h2{font-size:22px}}@media print{.sidebar,.topbar,.botnav,.toolbar,.page-head .no-print,.no-print{display:none!important}body,.app,.main,.content{background:#fff;margin:0;padding:0;display:block}.content{max-width:none}.qlabel{border:1px solid #999}}
